



# UNITED STATES PATENT AND TRADEMARK OFFICE

UNITED STATES DEPARTMENT OF COMMERCE  
United States Patent and Trademark Office  
Address: COMMISSIONER FOR PATENTS  
P.O. Box 1450  
Alexandria, Virginia 22313-1450  
[www.uspto.gov](http://www.uspto.gov)

| APPLICATION NO.                  | FILING DATE | FIRST NAMED INVENTOR | ATTORNEY DOCKET NO. | CONFIRMATION NO. |
|----------------------------------|-------------|----------------------|---------------------|------------------|
| 10/611,380                       | 06/30/2003  | Roni Rosner          | 42P17037            | 1513             |
| 8791                             | 7590        | 08/10/2007           | EXAMINER            |                  |
| BLAKELY SOKOLOFF TAYLOR & ZAFMAN |             |                      | JOHNSON, BRIAN P    |                  |
| 1279 OAKMEAD PARKWAY             |             |                      | ART UNIT            | PAPER NUMBER     |
| SUNNYVALE, CA 94085-4040         |             |                      | 2183                |                  |
| MAIL DATE                        |             | DELIVERY MODE        |                     |                  |
| 08/10/2007                       |             | PAPER                |                     |                  |

Please find below and/or attached an Office communication concerning this application or proceeding.

The time period for reply, if any, is set in the attached communication.

|                              |                        |                     |  |
|------------------------------|------------------------|---------------------|--|
| <b>Office Action Summary</b> | <b>Application No.</b> | <b>Applicant(s)</b> |  |
|                              | 10/611,380             | ROSNER ET AL.       |  |
|                              | <b>Examiner</b>        | <b>Art Unit</b>     |  |
|                              | Brian P. Johnson       | 2183                |  |

-- The MAILING DATE of this communication appears on the cover sheet with the correspondence address --  
**Period for Reply**

A SHORTENED STATUTORY PERIOD FOR REPLY IS SET TO EXPIRE 3 MONTH(S) OR THIRTY (30) DAYS, WHICHEVER IS LONGER, FROM THE MAILING DATE OF THIS COMMUNICATION.

- Extensions of time may be available under the provisions of 37 CFR 1.136(a). In no event, however, may a reply be timely filed after SIX (6) MONTHS from the mailing date of this communication.
- If NO period for reply is specified above, the maximum statutory period will apply and will expire SIX (6) MONTHS from the mailing date of this communication.
- Failure to reply within the set or extended period for reply will, by statute, cause the application to become ABANDONED (35 U.S.C. § 133). Any reply received by the Office later than three months after the mailing date of this communication, even if timely filed, may reduce any earned patent term adjustment. See 37 CFR 1.704(b).

#### Status

- 1) Responsive to communication(s) filed on 29 May 2007.
- 2a) This action is FINAL.                            2b) This action is non-final.
- 3) Since this application is in condition for allowance except for formal matters, prosecution as to the merits is closed in accordance with the practice under *Ex parte Quayle*, 1935 C.D. 11, 453 O.G. 213.

#### Disposition of Claims

- 4) Claim(s) 1-21 is/are pending in the application.
- 4a) Of the above claim(s) \_\_\_\_\_ is/are withdrawn from consideration.
- 5) Claim(s) \_\_\_\_\_ is/are allowed.
- 6) Claim(s) 1-21 is/are rejected.
- 7) Claim(s) \_\_\_\_\_ is/are objected to.
- 8) Claim(s) \_\_\_\_\_ are subject to restriction and/or election requirement.

#### Application Papers

- 9) The specification is objected to by the Examiner.
- 10) The drawing(s) filed on \_\_\_\_\_ is/are: a) accepted or b) objected to by the Examiner.  
 Applicant may not request that any objection to the drawing(s) be held in abeyance. See 37 CFR 1.85(a).  
 Replacement drawing sheet(s) including the correction is required if the drawing(s) is objected to. See 37 CFR 1.121(d).
- 11) The oath or declaration is objected to by the Examiner. Note the attached Office Action or form PTO-152.

#### Priority under 35 U.S.C. § 119

- 12) Acknowledgment is made of a claim for foreign priority under 35 U.S.C. § 119(a)-(d) or (f).
- a) All    b) Some \* c) None of:
  1. Certified copies of the priority documents have been received.
  2. Certified copies of the priority documents have been received in Application No. \_\_\_\_\_.
  3. Copies of the certified copies of the priority documents have been received in this National Stage application from the International Bureau (PCT Rule 17.2(a)).

\* See the attached detailed Office action for a list of the certified copies not received.

#### Attachment(s)

|                                                                                      |                                                                   |
|--------------------------------------------------------------------------------------|-------------------------------------------------------------------|
| 1) <input checked="" type="checkbox"/> Notice of References Cited (PTO-892)          | 4) <input type="checkbox"/> Interview Summary (PTO-413)           |
| 2) <input type="checkbox"/> Notice of Draftsperson's Patent Drawing Review (PTO-948) | Paper No(s)/Mail Date. _____                                      |
| 3) <input type="checkbox"/> Information Disclosure Statement(s) (PTO/SB/08)          | 5) <input type="checkbox"/> Notice of Informal Patent Application |
| Paper No(s)/Mail Date _____                                                          | 6) <input type="checkbox"/> Other: _____                          |

## DETAILED ACTION

1. Claims 1-21 are pending.

### ***Papers Filed***

2. Examiner acknowledges receipt of remarks and amended claims, filed on 29 May 2007.

### ***Claim Rejections - 35 USC § 103***

1. The following is a quotation of 35 U.S.C. 103(a) which forms the basis for all obviousness rejections set forth in this Office action:

(a) A patent may not be obtained though the invention is not identically disclosed or described as set forth in section 102 of this title, if the differences between the subject matter sought to be patented and the prior art are such that the subject matter as a whole would have been obvious at the time the invention was made to a person having ordinary skill in the art to which said subject matter pertains. Patentability shall not be negated by the manner in which the invention was made.

1. Claims 1-21 are rejected under 35 U.S.C. 103(a) as being unpatentable over Strombergson (U.S. Patent No. 6,807,621) in view of Harris (U.S. Patent No. 6,260,138).

3. As per claim 1, Strombergson discloses a device comprising:
  - a first device (Fig. 1 reservation unit 3A in combination with execution unit 4A) to track segment order associated with a first execution unit (Fig. 1 execution unit 4A);
  - a second device (Fig. 1 reservation unit 3B in combination with execution unit 4B) to track segment order associated with a second execution unit (Fig. 1

Art Unit: 2183

execution unit 4B); *The examiner asserts that a single instruction constitutes a segment of the program running on Strombergson's processor. Further, the examiner asserts that the reservation unit 3A/B receives instructions intended for execution unit 4A/B. The reservation unit tracks instructions.* Col. 4 lines 45-51 dictate that instructions are checked for irregularities in the order that they were received at the decode stage. The reservation unit must inherently track instruction order if it is to check for irregularities in the proper order.

and a third device (Fig. 1 commit stage 5) coupled to the first device and second device to track relative segment order between the first device and the second device. *The examiner asserts that the commit stage is coupled to the first and second execution and reservation units as pictured in Fig. 1. Further, the reorder buffer must track instructions through all execution units. If the reorder buffer did not keep track of instruction order, instructions would not be guaranteed to complete in the proper order, causing undesired operation of the processor.*

Strombergson identifies identifying instructions that are required to be flushed during a mispredicted branch (col 2 lines 14-23), but fails to disclose that these instructions are among consecutive sets of instructions with a switch point indicating a transition from a first to a second reorder buffer.

Harris discloses instruction path separated by conditional branch instructions, where different branch paths are sent to different execution units (fig. 6 and col 7 lines 9-37)

Strombergson would have been motivated to utilize this technique to increase the throughput of the processor, simplify recovery for mispredictions, and not suffer the same fallbacks associated to prior art Figs. 2-4.

It would have been obvious at the time of the invention for one of ordinary skill in the art to take the processing system of Strombergson and allow the conditional branch instructions to be separated into branch paths that are given separate execution units (and, in accordance with Strombergson fig. 1, separate reorder buffers).

4. As per claim 2, Strombergson/Harris discloses the device of claim 1, wherein the first device (Fig. 1 reservation unit 3A in combination with execution unit 4A) is operable to notify the third device (Fig. 1 commit stage 5) of a mispredicted instruction in a segment, and wherein the first device is operable to flush a first segment. (Col. 3 lines 34-60)

5. As per claim 3, Strombergson/Harris discloses the device of claim 2, wherein the third device (Fig. 1 commit stage 5) is operable to notify the second device (Fig. 1 reservation unit 3B in combination with execution unit 4B) of the mispredicted instruction in the segment, and wherein the second device is operable to flush a second segment. (Col. 3 lines 34-60)

6. As per claim 4, Strombergson/Harris discloses the device of claim 2, wherein the third device (Fig. 1 commit stage 5) is operable to notify the first

device (Fig. 1 reservation unit 3A in combination with execution unit 4A) of the mispredicted instruction in the segment, and wherein the first device is operable to flush a third segment. (Col. 3 lines 34-60)

2. As per claim 5, Strombergson/Harris discloses the device of claim 1, further comprising: a fetch control unit (Fig. 1 fetch unit 1 in combination with decode unit 2) to predict segment order (Col. 4 line 57-58), fetch segments and assign the segments to one of the first device and the second device during a flush operation. (Col. 7 lines 42-54)

2. As per claim 6, Strombergson/Harris discloses a method comprising:

- tracking the program order of a first set of instructions assigned to a first local reorder buffer (Fig. 1 reservation unit 3A in combination with execution unit 4A) in a first execution unit (Fig. 1 reservation unit 3A in combination with execution unit 4A);
- tracking the program order of a second set of instructions assigned to a second local reorder buffer (Fig. 1 reservation unit 3B in combination with execution unit 4B) in a second execution [unit] (Fig. 1 reservation unit 3B in combination with execution unit 4B);
- and tracking program order of the first set of instructions relative to the second set of instructions in a global reorder buffer (Fig. 1 commit stage 5). *The examiner asserts that since the commit stage contains a*

*reorder buffer (ROB 10), the stage is responsible to for tracking program order from all the execution stages.*

7. As per claim 7, Strombergson/Harris discloses the method of claim 6, further comprising:

notifying the global reorder buffer (Fig. 1 commit stage 5) when a mispredicted instruction occurs; (Col. 3 lines 34-60)  
initiating a flush operation in the global reorder buffer (Fig. 1 commit stage 5); (Col. 3 lines 34-60)  
and notifying the first local reorder buffer (Fig. 1 reservation unit 3A in combination with execution unit 4A) of the mispredicted instruction.  
(Col. 3, lines 34-60)

8. As per claim 8, Strombergson/Harris discloses the method of claim 7, further comprising: notifying a fetch control unit (Fig. 1 fetch unit 1 in combination with decode unit 2) of a mispredicted set of instructions. (Col. 3 line 51)

9. As per claim 9, Strombergson/Harris discloses the method of claim 6, further comprising: sending a signal to the second local reorder buffer (Fig. 1 reservation unit 3B in combination with execution unit 4B) to flush at least a third set of instructions. (Col. 3 line 58-60)

10. As per claim 10, Strombergson/Harris discloses the method of claim 6, further comprising: fetching a fourth set of instructions; and assigning the fourth set of instruction to the first reorder buffer during a flushing operation. *The examiner asserts that the processor will continue to process instructions, starting with the branch target instruction, after a conditional branch has been taken. These instructions will be issued to the functional stages, including the stage including the first reorder buffer, and will be executed once the flushing of the stage has been completed.*

11. As per claim 11, Strombergson/Harris discloses the method of claim 6, further comprising: retiring an instruction according to an indicator stored in the global reorder buffer(Fig. 1 commit stage 5). (Col. 8 lines 22-27) *The examiner asserts that indicators must exist to reorder instructions after execution.*

12. As per claim 12; Strombergson/Harris discloses a system comprising:  
a bus; (Fig. 1, line connecting memory 7 to fetch unit 1)  
a memory device coupled to the bus; (Fig. 1 memory 7)  
and a processor including a fetch control unit (Fig. 1 fetch unit 1  
and decode unit 2) to fetch instructions from the memory device, a first  
execution unit (Fig. 1 reservation unit 3A in combination with execution  
unit 4A) to process one or more of the fetched instructions, a second  
execution unit (Fig. 1 reservation unit 3B in combination with execution  
unit 4B) to process one or more of the fetched instructions, a first reorder

buffer (Fig. 1 reservation unit 3A in combination with execution unit 4A) to track instructions assigned to the first execution unit, a second reorder buffer (Fig. 1 reservation unit 3B in combination with execution unit 4B) to track instructions assigned to the second execution unit, and a global reorder buffer (Fig. 1 commit stage 5) to track instruction order of instructions assigned to the first reorder buffer relative to the second reorder buffer. (Col. 8 lines 22-27) *The examiner asserts that the reservation station in combination with the execution unit track a given instruction as it waits to be, and is finally executed. The examiner asserts that the reorder buffer 10 in commit stage 5 tracks the order of instructions as it retires instructions in their proper order.*

By storing data for a set of switch points, the data indicating a transition in assignment of consecutive sets of instructions from the first reorder buffer to the second reorder buffer, the global reorder buffer to identify a switch point from the set of switch points that is associated with an instruction occurring after a mispredicted instruction (Harris Fig. 6 and col7 lines 9-37).

13. As per claim 13, Strombergson/Harris discloses the system of claim 12, wherein the first reorder buffer is operable to signal the global reorder buffer upon detection of a mispredicted instruction. (Col. 3 lines 34-60)

14. As per claim 14, Strombergson/Harris discloses the system of claim 12, wherein the first reorder buffer is operable to flush a first set of instructions upon

detection of a mispredicted instruction (Col. 3 lines 34-60), and wherein the fetch control unit assigns a second set of instructions to the first reorder buffer based on a set of load balancing criteria. *The examiner asserts that the processor will continue to process instructions, starting with the branch target instruction, after a conditional branch has been taken. These instructions will be issued to the functional stages, including the stage including the first reorder buffer, and will be executed once the flushing of the stage has been completed.*

15. As per claim 15, Strombergson/Harris discloses a machine readable medium having stored therein instructions, which when executed cause a machine to perform a set of operations comprising:

tracking the program order of a first set of instructions assigned to a first local tracking device in a first execution unit (Fig. 1 reservation unit 3A in combination with execution unit 4A); *The examiner asserts that the reservation station in combination with the execution unit track a given instruction as it waits to be, and is finally executed.*

tracking the program order of a second set of instructions assigned to a second local tracking device in a second execution unit (Fig. 1 reservation unit 3B in combination with execution unit 4B); *The examiner asserts that the reservation station in combination with the execution unit track a given instruction as it waits to be, and is finally executed.*

and tracking program order of the first set of instructions relative to the second set of instructions in a global tracking device. (Fig. 1 commit

stage 5) *The examiner asserts that the reorder buffer 10 in commit stage 5 tracks the order of instructions as it retires instructions in their proper order.*

Bye storing data for a set of switch points, the data indicating a transition in assignment of consecutive sets of instructions from the first reorder buffer to the second reorder buffer, the global reorder buffer to identify a switch point from the set of switch points that is associated with an instruction occurring after a mispredicted instruction (Harris Fig. 6 and col7 lines 9-37).

16. As per claim 16, Strombergson/Harris discloses the machine readable medium of claim 15, having further instructions stored therein which when executed cause a machine to perform a set of operations further comprising: notifying the global tracking device (Fig. 1 commit stage 5) when a mispredicted instruction occurs. (Col. 3 line 55-57)

17. As per claim 17, Strombergson/Harris discloses the machine readable medium of claim 16, having further instructions stored therein which when executed cause a machine to perform a set of operations further comprising: tracking a first set of switch points in the global tracking device (Fig. 1 commit stage 5). *The examiner further asserts that the reorder buffer 10 tracks a given instruction compared to prior and subsequent instructions to maintain proper instruction ordering.*

18. As per claim 18, Strombergson/Harris discloses the machine readable medium of claim 16, having further instructions stored therein which when executed cause a machine to perform a set of operations further comprising: flushing a second set of switch points based on the mispredicted instruction. *The examiner asserts that when a conditional branch instruction is mispredicted, instructions currently in other stages of the pipeline are flushed as described in col. 3 lines 34-60.*

19. As per claim 19, Strombergson/Harris discloses an apparatus comprising:

a means for tracking the program order of a first set of instructions assigned to a first local tracking device (Fig. 1 reservation unit 3A in combination with execution unit 4A) in a first execution unit (Fig. 1 reservation unit 3A in combination with execution unit 4A); *The examiner asserts that the reservation station in combination with the execution unit track a given instruction as it waits to be, and is finally executed.*

a means for tracking the program order of a second set of instructions assigned to a second local tracking device (Fig. 1 reservation unit 3B in combination with execution unit 4B) in a second execution unit (Fig. 1 reservation unit 3B in combination with execution unit 4B); *The examiner asserts that the reservation station in combination with the execution unit track a given instruction as it waits to be, and is finally executed.*

and a means for tracking program order of the first set of instructions relative to the second set of instructions in a global tracking device. (Fig. 1 commit stage 5) *The examiner asserts that the reorder buffer 10 in commit stage 5 tracks the order of instructions as it retires instructions in their proper order.*

By storing data for a set of switch points, the data indicating a transition in assignment of consecutive sets of instructions from the first reorder buffer to the second reorder buffer, the global reorder buffer to identify a switch point from the set of switch points that is associated with an instruction occurring after a mispredicted instruction (Harris Fig. 6 and col7 lines 9-37).

20. As per claim 20, Strombergson/Harris discloses the apparatus of claim 19, further comprising: a means for notifying the global tracking device when a mispredicted instruction occurs. (Col. 3 lines 34-60)
  
21. As per claim 21, Strombergson/Harris discloses the apparatus of claim 19, further comprising: a means for flushing at least a third set of instructions in the first local tracking device. (Col. 3 lines 34-60)

Art Unit: 2183

3. The following is a quotation of 35 U.S.C. 103(a) which forms the basis for all obviousness rejections set forth in this Office action:

(a) A patent may not be obtained though the invention is not identically disclosed or described as set forth in section 102 of this title, if the differences between the subject matter sought to be patented and the prior art are such that the subject matter as a whole would have been obvious at the time the invention was made to a person having ordinary skill in the art to which said subject matter pertains. Patentability shall not be negated by the manner in which the invention was made.

4. Claims 22-26 are rejected under 35 U.S.C. 103(a) as being unpatentable over Strombergson.

Regarding claims 22-26, Strombergson discloses the method and apparatus of claims 1, 6, 12, 15 and 19, comprising data for a set of switch points (col 1 lines 26-30).

Strombergson discloses in col 1 lines 26-30 that "super-scalar processors are also known which comprise multiple pipelines processing instructions simultaneously when adjacent instructions have no data dependencies between them." It follows then, in many processing systems, that these instructions that were intended for a particular execution unit, are transitioned to another execution unit once their data dependencies are evaluated just prior to execution. Strombergson, however, does not particularly disclose this strategy.

Examiner takes Official Notice that it is common in the art to transition an instruction intended for a particular execution unit to a different execution unit as the data dependencies are evaluated.

Strombergson would have been motivated to utilize this technique in order to maximize instruction level parallelism making the processing system more efficient in order to optimize the technique described in col 1 lines 26-30.

Each of the new claims discloses "data for a set of switch points". Applicant's specification states that, "A switch point is the first segment in a sequence of consecutive segments that have been assigned to a single execution cluster or local order buffer." This appears to be an adequate definition that can be properly read into the claims. The "segments", however, are shown in some embodiments to be sequences of instructions, but do not have an appropriate definition that can be read into the claims. Segments will be interpreted to be a plurality of instruction bits. This may include a portion of an instruction, an entire instruction, or several instructions. It then follows that the "switch points" are also instruction bits. The claims, in particular, each state that the data for the switch points indicate a transition in consecutive segment (instruction assignment) from the first execution unit to the second execution unit. In essence, it appears that claim requires that instruction data override some pre-existing or default decision to go to a particular execution unit and, in part, assign one or more instructions to a different execution unit.

Therefore, it would have been obvious at the time of the invention for one of ordinary skill in the art to take the processing system of Strombergson and allow the data for a set of switch points (data operand values for one or more instructions), the data indicating (by data dependencies) a transition in assignment of consecutive sets of instructions (in cases of multiple dependencies) from the first execution unit to the second execution unit (to improve instruction level parallelism).

***Response to Arguments***

5. Applicant's arguments with respect to the claims have been considered but are moot in view of the new ground(s) of rejection. The discussion of switch points in context with the mispredicted instructions has overcome the previous rejection. A new grounds rejection is presented with this Office Action.

***Conclusion***

6. Applicant's amendment necessitated the new ground(s) of rejection presented in this Office action. Accordingly, **THIS ACTION IS MADE FINAL**. See MPEP § 706.07(a). Applicant is reminded of the extension of time policy as set forth in 37 CFR 1.136(a).

A shortened statutory period for reply to this final action is set to expire THREE MONTHS from the mailing date of this action. In the event a first reply is filed within TWO MONTHS of the mailing date of this final action and the advisory action is not mailed until after the end of the THREE-MONTH shortened statutory period, then the shortened statutory period will expire on the date the advisory action is mailed, and any extension fee pursuant to 37 CFR 1.136(a) will be calculated from the mailing date of the advisory action. In no event, however, will the statutory period for reply expire later than SIX MONTHS from the date of this final action.

Any inquiry concerning this communication or earlier communications from the examiner should be directed to Brian P. Johnson whose telephone number is (571) 272-2678. The examiner can normally be reached on 8-4:30 M-F.

If attempts to reach the examiner by telephone are unsuccessful, the examiner's supervisor, Eddie Chan can be reached on (571) 272-4162. The fax phone number for the organization where this application or proceeding is assigned is 571-273-8300.

Information regarding the status of an application may be obtained from the Patent Application Information Retrieval (PAIR) system. Status information for published applications may be obtained from either Private PAIR or Public PAIR. Status information for unpublished applications is available through Private PAIR only. For more information about the PAIR system, see <http://pair-direct.uspto.gov>. Should you have questions on access to the Private PAIR system, contact the Electronic Business Center (EBC) at 866-217-9197 (toll-free). If you would like assistance from a USPTO Customer Service Representative or access to the automated information system, call 800-786-9199 (IN USA OR CANADA) or 571-272-1000.



EDDIE CHAN  
SUPERVISORY PATENT EXAMINER  
TECHNOLOGY CENTER 2100